草庐IT

xml - Xpath 表达式

全部标签

ruby - 正则表达式用逗号和空格分割字符串,但忽略带连字符的单词?

我需要一个正则表达式来用逗号和/或空格分隔字符串,但忽略带连字符的单词——最好的方法是什么?所以,例如——我想要这个……"foobar,zap-foo,baz".split(/[\s]+/)返回["foo","bar","zap-foo","baz"]但是当我这样做时,它包括像这样的逗号......["foo","bar,","zap-foo,","baz"] 最佳答案 "foobar,zap-foo,baz".split(/[\s,]+/) 关于ruby-正则表达式用逗号和空格分割字符

Ruby 使用正则表达式从字符串中提取数据

我正在做一些网络抓取,这是数据的格式Sr.No.Course_CodeCourse_NameCreditGradeAttendance_Grade我收到的实际字符串是以下形式1CA727PRINCIPLESOFCOMPILERDESIGN3AM我感兴趣的是Course_Code、Course_Name和Grade,在此示例中,这些值将是Course_Code:CA727Course_Name:PRINCIPLESOFCOMPILERDESIGNGrade:A有什么方法可以让我使用正则表达式或其他技术轻松提取此信息,而不是手动解析字符串。我在1.9模式下使用jruby。

ruby-on-rails - RSpec:通过正则表达式匹配字符串数组

我正在使用rspec测试我的模型的验证,并期待一条错误消息。但是,消息的确切文本可能会发生变化,所以我想更宽容一点,只检查部分消息。由于Spec::Matchers::include方法只适用于字符串和集合,我目前正在使用这个结构:@user.errors[:password].any?{|m|m.match(/istooshort/)}.shouldbe_true这可行,但对我来说似乎有点麻烦。是否有更好(即更快或更像ruby​​)的方法来检查数组是否包含正则表达式的字符串,或者是否有一个rspec匹配器可以做到这一点? 最佳答案

ruby - 尝试使用 nokogiri 获取 xml 文件中 cdata 标签内的内容

我已经看到了几件事,但到目前为止似乎没有任何效果。我正在使用nokogirionrails3ruby​​1.9.2通过url解析xml。xml的片段如下所示:我正在尝试解析它以获取与NewsLineText关联的文本r=node.at_xpath('.//newslinetext')ifnode.at_xpath('.//newslinetext')s=node.at_xpath('.//newslinetext').textifnode.at_xpath('.//newslinetext')t=node.at_xpath('.//newslinetext').contentifnod

ruby - 正则表达式 "empty range in char class error"

我的代码中有一个正则表达式,用于匹配url的模式并抛出错误:/^(http|https):\/\/([\w-]+\.)+[\w-]+([\w-.\/?%&=]*)?$/错误是“字符类错误中的空范围”。我发现原因在([\w-.\/?%&=]*)?部分。Ruby似乎将\w-.中的-识别为范围运算符,而不是文字-。给dash加上escape后问题解决。但原来的正则表达式在我同事的机器上运行良好。我们使用相同版本的osx、rails和ruby:Ruby版本是ruby1.9.3p194,rails是3.1.6,osx是10.7.5。在我们将代码部署到我们的Heroku服务器之后,一切都运行良好。

ruby-on-rails - 如何呈现 XML 模板,然后在 Ruby on Rails 3.2.8 中使用 SEND_DATA?

谁能帮我处理XML模板渲染和发送数据?我有一个Controller:defshow@calculation=Calculation.find(params[:id])respond_todo|format|format.html#show.html.erbformat.json{renderjson:@calculation}format.xml{send_data(:partial=>show.xml.erb,:filename=>"my_file.xml")}format.pdf{render:format=>false}endend但是我有很多关于“堆栈级别太深”的错误如果我用{

ruby - XPath 轴,获取所有后续节点直到

我有以下HTML示例:FoobarloremipsumetcBarbazdumdumdumpoopfiddles我希望提取“Foobar”标题后的所有段落,直到到达“Barbaz”标题(“Barbaz”标题的文本未知,所以很遗憾我无法使用答案由bougyman提供)。现在我当然可以使用//h2[text()='Foobar']/following::p之类的东西,但这当然会抓取此后的所有段落header。因此,我可以选择遍历节点集并将段落插入数组,直到文本与下一个header的文本相匹配,但老实说,这远不如在XPath中完成这件事那么酷。有没有办法做到这一点我想念的?

ruby 正则表达式 "contains a word"

在Ruby中,如何编写正则表达式来检查提交的单个单词?假设我有一个接受文本的Web表单。我知道如果我想看看句子--only--是否包含"join"我可以使用ifthe_body=="join"但这只有在整个文本提交都是“加入”时才有效。如何捕捉这样的提交:“我想加入你们的俱乐部?”或者“请加入我”谢谢! 最佳答案 你可以这样做string=~/join/i#/imakesitcaseinsensitive或string.match(/join/i)关于性能评论的一点更新:>>s="iwanttojoinyourclub">>n=50

Ruby 正则表达式\1 对 gsub 意味着什么

\1是做什么的?例如"foobarbag".gsub(/(bar)/,'car\1')我相信这与您使用括号的方式有关,但我不太确定。有人可以向我解释吗?你能做像\2这样的事情吗?如果是这样,那会做什么? 最佳答案 您在搜索部分用括号括起来的每个项目将对应于替换部分中的一个数字\1、\2等。在您的示例中,只有一个项目被括号包围,即"(bar)"项目,因此您放置\1的任何地方都是括号,将被换入。你可以多次输入\1,如果你想重复找到的项目,这很方便,所以你可以合法地写car\1\1\1和"bar"将交换三次。\2没有用处,因为括号中只有一

ruby - 在 Ruby 中评估许多 bool 表达式,如 Array#join

在Ruby中,您可以使用Array#join使用可选的分隔符简单地将多个字符串连接在一起。["a","b","c"].join#=>"abc"["a","b","c"].join("-")#=>"a-b-c"我想知道是否有很好的语法糖可以用一堆bool表达式做类似的事情。例如,我需要将一堆表达式&&放在一起。但是,将使用哪些表达式由用户输入决定。所以与其做一堆cumulative_value&&=expression[:a]ifuser[:input][:a]我想先根据输入收集所有的表达式,然后&&一举将它们全部收集起来。像这样的东西:be1=x>ybe2=Proc.new{|stri